<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>菜单和权限管理</title>
        <meta name="renderer" content="webkit">
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
        <link rel="stylesheet" href="../../../lib/layui-v2.5.5/css/layui.css" media="all">
        <link rel="stylesheet" href="../../../lib/font-awesome-4.7.0/css/font-awesome.min.css" media="all">
        <link rel="stylesheet" href="../../../css/public.css" media="all">
        <style>
            .layui-iconpicker-body.layui-iconpicker-body-page .hide {display: none;}
        </style>
    </head>

    <body>
        <div class="layuimini-container">
            <div class="layuimini-main">
                <!--搜索开始-->
                <fieldset class="table-search-fieldset">
                    <legend>搜索信息</legend>
                    <div style="margin: 10px 10px 10px 10px">
                        <form class="layui-form layui-form-pane" action="" id="searchFrm">
                            <div class="layui-form-item">
                                <div class="layui-inline">
                                    <label class="layui-form-label">关键字</label>
                                    <div class="layui-input-inline">
                                        <input type="text" name="title" id="search_title" autocomplete="off"
                                               class="layui-input">
                                    </div>
                                </div>
                                <div class="layui-inline">
                                    <button class="layui-btn layui-btn-primary" id="data-search-btn">
                                        <i
                                                class="layui-icon">
                                        </i>
                                        搜 索
                                    </button>
                                    <button type="reset" class="layui-btn layui-btn-primary btn_reset"
                                            lay-filter="data-search-btn">
                                        <i class="layui-icon layui-icon-refresh"></i>
                                        重 置
                                    </button>
                                </div>
                            </div>
                        </form>
                    </div>
                </fieldset>
                <!--搜索结束-->
                <!--表格开始-->
                <button style="margin-top: 10px;"
                        class="layui-btn layui-btn-sm layui-btn-normal data-delete-btn menubtn_add"
                        id="addMenuBtn">
                    <i class="layui-icon layui-icon-addition"></i>
                    添 加
                </button>
                <table class="layui-hide" id="menuTable" lay-filter="menuTable"></table>
                <div style="display: none" id="menuTableBar">
                    <a class="layui-btn layui-btn-xs layui-btn-warm data-count-delete menubtn_update" lay-event="update"><i class="layui-icon layui-icon-edit"></i> 修 改 </a>
                    <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete menubtn_delete" lay-event="delete"><i class="layui-icon layui-icon-delete"></i> 删 除 </a>
                </div>

                <script type="text/html" id="spreadTpl">
                    <!-- 这里的 checked 的状态只是演示 -->
                    <input type="checkbox" name="spread" value="{{d.id}}" lay-skin="switch" lay-text="展开|不展开"
                           lay-filter="spreadSwitch" {{ d.spread== 1 ? 'checked' : '' }}>
                </script>
                <script type="text/html" id="availableTpl">
                    <!-- 这里的 checked 的状态只是演示 -->
                    <input type="checkbox" name="available" value="{{d.id}}" lay-skin="switch" lay-text="可用|不可用"
                           lay-filter="availableSwitch" {{ d.available== 1 ? 'checked' : '' }}>
                </script>

                <!--表格结束-->

                <!--添加和修改的弹出层开始-->
                <div id="addOrUpdateDiv" style="display: none;padding: 0.3125rem">
                    <form method="post" class="layui-form layui-form-pane" lay-filter="dataFrm" id="dataFrm">
                        <div class="layui-form-item" id="div_pid">
                            <label class="layui-form-label">菜单类型</label>
                            <div class="layui-input-block">
                                <input type="radio" name="type" lay-filter="typeFilter" value="topmenu" title="顶部菜单">
                                <input type="radio" name="type" lay-filter="typeFilter" value="leftmenu" title="左侧菜单"
                                       checked="">
                                <input type="radio" name="type" lay-filter="typeFilter" value="permission" title="按钮权限">
                            </div>
                        </div>
                        <div class="layui-form-item item_leftmenu item_permission">
                            <label class="layui-form-label">父级菜单</label>
                            <div class="layui-input-inline">
                                <input type="hidden" name="pid" id="p_id"/>
                                <input type="text" name="pid_name" id="p_name" readonly="readonly" autocomplete="off"
                                       placeholder="请选择父级菜单和权限" class="layui-input">
                            </div>
                            <div class="layui-input-inline">
                                <a class="layui-btn layui-btn-warm" id="doSelectMenu"><label
                                        class="layui-icon layui-icon-male"></label>选择
                                </a>
                            </div>
                        </div>
                        <div class="layui-form-item ">
                            <label class="layui-form-label">名称</label>
                            <div class="layui-input-block">
                                <input type="hidden" name="id"/>
                                <input type="text" name="title" lay-verify="required" autocomplete="off"
                                       placeholder="请输入菜单和权限名称" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-form-item">
                            <label class="layui-form-label">编码</label>
                            <div class="layui-input-block">
                                <input type="text" name="typecode" autocomplete="off" placeholder="请输入菜单和权限地址"
                                       class="layui-input">
                            </div>
                        </div>
                        <div class="layui-form-item item_topmenu  item_leftmenu">
                            <label for="" class="layui-form-label">图标</label>
                            <div class="layui-input-block">
                                <input type="text" id="iconPicker1" lay-filter="iconPicker2" name="icon"
                                       autocomplete="off" placeholder="请输入菜单和权限地址"
                                       class="layui-input hide">
                            </div>
                        </div>
                        <div class="layui-form-item  item_leftmenu">
                            <label class="layui-form-label">链接地址</label>
                            <div class="layui-input-block">
                                <input type="text" name="href" autocomplete="off" placeholder="请输入菜单和权限地址"
                                       class="layui-input">
                            </div>
                        </div>
                        <div class="layui-form-item item_leftmenu">
                            <label class="layui-form-label">TARGET</label>
                            <div class="layui-input-block">
                                <input type="radio" name="target" value="_self" title="_self" checked="">
                                <input type="radio" name="target" value="_blank" title="_blank">
                            </div>
                        </div>
                        <div class="layui-form-item">
                            <label class="layui-form-label">排序码</label>
                            <div class="layui-input-block">
                                <input type="text" name="ordernum" id="ordernum" lay-verify="required"
                                       autocomplete="off" placeholder="请输入排序码" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-form-item">
                            <div class="layui-input-block" style="text-align: center;">
                                <a class="layui-btn " lay-submit="" lay-filter="doSubmit"><label
                                        class="layui-icon layui-icon-release"></label>提交
                                </a>
                                <a class="layui-btn layui-btn-warm" onclick="javascript:$('#dataFrm')[0].reset()"
                                   lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置
                                </a>
                            </div>
                        </div>
                    </form>
                </div>
                <!--添加和修改的弹出层结束-->
            </div>
        </div>
        <script src="../../../lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script>
        <script src="../../../lib/layui-v2.5.5/layui.js" charset="utf-8"></script>
        <script src="../../../js/lay-config.js?v=1.0.4" charset="utf-8"></script>
        <script src="../../../lib/jq-module/jquery.particleground.min.js" charset="utf-8"></script>
        <script src="../../../lib/common/jquery.cookie.min.js" charset="utf-8"></script>
        <script src="../../../lib/common/common.js" charset="utf-8"></script>
        <script src="../../../lib/common/selectLayer.js" charset="utf-8"></script>

        <script>
            layui.use(['form', 'table', 'layer', 'treeTable', 'laydate', 'iconPickerFa'], function () {
                var iconPickerFa = layui.iconPickerFa;
                var form = layui.form;
                var table = layui.table;
                var layer = layui.layer;
                var laydate = layui.laydate;
                var treeTable = layui.treeTable;

                iconPickerFa.render({
                    // 选择器，推荐使用input
                    elem: '#iconPicker1',
                    // fa 图标接口
                    url: "../../../lib/font-awesome-4.7.0/less/variables.less",
                    // 是否开启搜索：true/false
                    search: true,
                    // 是否开启分页
                    page: true,
                    // 每页显示数量，默认12
                    limit: 12,
                    // 点击回调
                    click: function (data) {
                    },
                    // 渲染成功后的回调
                    success: function (d) {
                    }
                });

                var tableIns = treeTable.render({
                    tree: {
                        iconIndex: 1,  // 折叠图标显示在第几列
                        idName: 'id',  // 自定义id字段的名称
                        pidName: 'pid',  // 自定义标识是否还有子节点的字段名称
                        isPidData: true,// 是否是pid形式数据
                        openName: 'spread'  // 自定义默认展开的字段名
                    },
                    elem: '#menuTable',
                    height: 'full-250', //高度最大化减去差值
                    cellMinWidth: true,
                    cols: [
                        {type: "numbers"},
                        {field: 'title', title: '菜单或权限名称', width: 230},
                        {
                            field: 'type', title: '类型', align: "center", templet: function (d) {
                                if (d.type == 'topmenu') {
                                    return '<span class="layui-badge layui-bg-red">顶部菜单</span>';
                                }
                                if (d.type == 'leftmenu') {
                                    return '<span class="layui-badge layui-bg-blue">左侧菜单</span>';
                                } else {
                                    return '<span class="layui-badge layui-bg-green">权限</span>';
                                }
                            }
                        },
                        {field: 'href', title: '地址', align: "center"},
                        {field: 'typecode', title: '编码', align: "center"},
                        {
                            field: 'icon', title: '图标', align: "center", templet: function (d) {
                                var x = "<i class='fa " + d.icon + "' ></i>";
                                return x;
                            }
                        },
                        {field: 'target', title: 'TARGET', align: "center"},
                        {field: 'ordernum', title: '排序码', align: "center"},
                        {field: 'spread', title: '是否展开', align: "center", templet: '#spreadTpl'},
                        {field: 'available', title: '是否可用', align: "center", templet: '#availableTpl'},
                        {title: '操作',width: 250, templet: '#menuTableBar', fixed: "right", align: "center"}
                    ],
                    reqData: function (data, callback) {
                        if (data == undefined) {
                            // 在这里写ajax请求，通过callback方法回调数据
                            $.get(api + 'menu/loadAllMenu', function (res) {
                                callback(res.data);  // 参数是数组类型
                            });
                        } else {
                            callback([]);  //回调一个空数据去渲染表格
                        }

                    }
                });

                // 监听搜索操作
                $("#data-search-btn").on("click", function () {
                    var title = $("#search_title").val();
                    if (title) {
                        tableIns.filterData(title);
                    } else {
                        tableIns.reload();
                    }
                    return false;
                });

                //监听表单元素的事件
                //监听展开操作
                form.on('switch(spreadSwitch)', function (obj) {
                    $.post(api + "menu/updateMenu", {id: this.value, spread: obj.elem.checked ? 1 : 0}, function (res) {
                        layer.msg(res.msg);
                        tableIns.reload();
                    })
                    layer.tips(this.value + ' ' + this.name + '：' + obj.elem.checked, obj.othis);
                });

                //监听可用操作
                form.on('switch(availableSwitch)', function (obj) {
                    $.post(api + "menu/updateMenu", {
                        id: this.value,
                        available: obj.elem.checked ? 1 : 0
                    }, function (res) {
                        layer.msg(res.msg);
                        tableIns.reload();
                    })
                });


                //监听添加按钮的事件
                $("#addMenuBtn").click(function () {
                    openAddmenu(); //打开添加的弹出层
                })

                form.on('radio(typeFilter)', function (data) {
                    $(".item_topmenu").show();
                    $(".item_leftmenu").show();
                    $(".item_permission").show();
                    if (data.value == 'topmenu') {
                        $(".item_leftmenu").hide();
                        $(".item_permission").hide();
                        $(".item_topmenu").show();
                    } else if (data.value == 'leftmenu') {
                        $(".item_permission").hide();
                        $(".item_topmenu").hide();
                        $(".item_leftmenu").show();
                    } else {
                        $(".item_leftmenu").hide();
                        $(".item_topmenu").hide();
                        $(".item_permission").show();
                    }
                });

                //监听行数据的事件
                treeTable.on('tool(menuTable)', function (obj) {
                    var data = obj.data;
                    if (obj.event === 'delete') {
                        $.get(api + "menu/getMenuChildrenCountById", {id: data.id}, function (res1) {
                            if (res1.data > 0) {
                                layer.msg("当前菜单和权限有子菜单和权限，请选择删除子菜单和权限");
                            } else {
                                layer.confirm('真的删除【' + data.title + '】这个菜单和权限吗?', function (index) {
                                    $.post(api + "menu/deleteMenu", {id: data.id}, function (res) {
                                        layer.msg(res.msg);
                                        obj.del();
                                        layer.close(index);
                                    })
                                });
                            }
                        })
                    } else if (obj.event === 'update') {
                        openUpdatemenu(data);
                    }
                });

                //打开添加公告的弹层
                var mainIndex;
                var url;  //动态的url
                function openAddmenu() {
                    mainIndex = layer.open({
                        type: 1,
                        title: '添加菜单和权限',
                        content: $("#addOrUpdateDiv"),
                        area: ['800px', '600px'],
                        success: function (index) {
                            url = api + "menu/addMenu";
                            //重置表单
                            $("#dataFrm")[0].reset();
                            //加载最大的排序码
                            $.get(api + "menu/queryMenuMaxOrderNum", function (res) {
                                $("#ordernum").val(res.data);
                            });
                            $(".item_permission").hide();
                            $(".item_topmenu").hide();
                            $(".item_leftmenu").show();
                        }
                    });
                }

                function openUpdatemenu(data) {
                    mainIndex = layer.open({
                        type: 1,
                        title: '修改[' + data.title + ']菜单和权限',
                        content: $("#addOrUpdateDiv"),
                        area: ['800px', '600px'],
                        success: function (index) {
                            url = api + "menu/updateMenu";
                            //装载数据表格
                            form.val("dataFrm", data);
                            $.get(api + "menu/getMenuById", {id: data.pid}, function (res) {
                                $("#p_name").val(res.data.title);
                            });
                            if (data.type == 'topmenu') {
                                $(".item_leftmenu").hide();
                                $(".item_permission").hide();
                                $(".item_topmenu").show();
                            } else if (data.type == 'leftmenu') {
                                $(".item_permission").hide();
                                $(".item_topmenu").hide();
                                $(".item_leftmenu").show();
                            } else {
                                $(".item_leftmenu").hide();
                                $(".item_topmenu").hide();
                                $(".item_permission").show();
                            }
                        }
                    });
                }

                //提交数据
                form.on("submit(doSubmit)", function (data) {
                    var params = $("#dataFrm").serialize();
                    $.post(url, params, function (res) {
                        layer.msg(res.msg);
                        if (res.code == 200) {
                            tableIns.reload();
                        }
                        layer.close(mainIndex);
                    })
                    return false;
                })


                //监听菜单和权限选择的按钮事件打开菜单和权限选择的弹出层
                $("#doSelectMenu").click(function () {
                    var p_id = $("#p_id").val();
                    openMenuSelecter(p_id, function (id, name) {
                        $("#p_id").val(id);
                        $("#p_name").val(name);
                    });
                });
            });
        </script>

    </body>
</html>
